草庐IT

SQL 在一个查询中统一 COUNT 和 SUM

全部标签

ruby 调试器直接进入一个 block ?

在以下Ruby代码中:#!/usr/bin/envrubyrequire'debugger'defhelloputs"hello"ifblock_given?yieldendenddefmaindebuggerputs"testbegin..."hellodo#在调试时很常见,我不关心让出block的函数的实现,我只想直接进入block,而不用手动在那里设置断点。在ruby​​-debug19或调试器中是否存在对这种“步入block”的支持? 最佳答案 您是否尝试过对“continue”使用“c”命令?它可以选择使用行号,因此,根据

sql - Rails 控制台和 Rails 服务器日志中输出的颜色是什么意思?

我在Ubuntu14.04中的通用终端(应用程序简称为“终端”)内运行railsserver和railsconsole。每当我运行涉及数据库的命令时,控制台都会输出它发送的SQL查询,但有时文本是绿松石色,有时是紫​​色。例如在这个控制台输出中:2.2.2:025>pl=ProjectLevel.find_by(name:'Premium')ProjectLevelLoad(0.5ms)SELECT"project_levels".*FROM"project_levels"WHERE"project_levels"."deleted_at"ISNULLAND"project_level

sql - 按年、月分组,然后在 ActiveRecord 3 中计数

我正在尝试统计一年和一个月内创建的所有用户,但以下内容似乎没有按预期工作。User.group("YEAR(created_AT),MONTH(created_at)").count("DISTINCT(id),YEAR(created_at),MONTH(created_at)")我在找类似的东西{2011=>{1=>222,2=>333,4=>444,5=>667...}}但是我得到了{1=>222,2=>333,4=>444,5=>667...}我是不是遗漏了什么,或者ActiveRecord不能在一次查询中给我这个结果? 最佳答案

ruby-on-rails - 在一个 Rails 应用程序中使用 PostgreSQL 的 MongoDB

我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多

ruby-on-rails - 给定一个 json 对象,如何在 rails 中遍历该对象

我的应用程序正在将以下json对象发布到Rails。[{\"completed\":false,\"id\":196,\"position\":0,\"title\":\"Item1\",\"updated_at\":\"2011-08-03T21:17:09Z\"},{\"completed\":false,\"id\":193,\"position\":1,\"title\":\"ItemX\",\"updated_at\":\"2011-08-03T21:16:19Z\"},{\"completed\":false,\"id\":197,\"position\":2,\"titl

ruby - 每次请求都会启动一个新的 sinatra 实例吗?

当一个新的http请求进来时,是否会启动一个新的sinatra实例,例如是否要初始化sinatra,或者只是调用sinatra的前一个实例(相应的get/post方法/路由)的方法?感谢您提供任何文档链接,我找不到任何文档链接。如果该行为依赖于部署类型——WEBrick/Passenger等,那也很有趣 最佳答案 为每个请求创建一个新类。然而,这不是Rack完成的。这是Sinatra的一个特性。如果您想深入了解细节:该实例实际上不是使用Sinatra::Application.new创建的,而是使用Sinatra::Applicat

ruby - 如何将类名作为变量传递给ruby中的另一个类

我正在尝试学习用ruby​​创建一个多类程序。我编写了一个引擎类和一些其他类,如城市、街道等,但在将类名作为变量传递给其他类时遇到了问题。下面的代码抛出错误:“City.rb:15:in'intro':undefinedlocalvariableormethodgame'for#(NameError)”。我在某种程度上理解这个问题,但我认为这个城市不需要知道任何关于游戏对象,我认为它只需要获取它并将其传回即可。但表面上我对如何在类之间传递变量(尤其是类名)有误解。我的设计有什么问题?#Game.rbrequire'./City.rb'classEnginedefinitialize(c

ruby - 如何将一个 config.ru 文件变成一个单独的 Rack 应用程序?

我有一个开始有重复代码的config.ru文件:map'/route1'dorunSampleApp.newendmap'/route2'dorunSampleApp.newend我想把这个config.ru文件变成它自己的Rack应用程序,这样我所要做的就是:map'/'dorunMyApp.newend创建自己的Rack应用程序的正确方法是什么?具体来说,我如何创建一个类,以便我可以在我的类中使用map方法来定义一堆路由?解决方法:这是一个可行的解决方案:classMyAppdefinitialize@app=Rack::Builder.newdo#copycontentsofyo

ruby - 我怎样才能随机遍历一个大范围?

我想随机遍历一个范围。每个值只会被访问一次,所有值最终都会被访问。例如:classArraydefshuffleret=dupj=lengthi=0whilej>1r=i+rand(j)ret[i],ret[r]=ret[r],ret[i]i+=1j-=1endretendend(0..9).to_a.shuffle.each{|x|f(x)}其中f(x)是对每个值进行操作的函数。Fisher-Yatesshuffle用于有效地提供随机排序。我的问题是shuffle需要对数组进行操作,这并不酷,因为我正在处理天文数字的大数。Ruby会快速消耗大量RAM来尝试创建一个巨大的数组。想象一下

ruby-on-rails - 事件管理员 CSV 导出自定义查询范围

我正在使用活跃的管理员导出CSV选项。它返回与特定表相关的所有值。我只想要特定月份的报告。有人能帮忙吗? 最佳答案 您可以编写自己的csv导出器collection_action:download_report,:method=>:getdousers=User.where('created_at>=?',Date.today-1.month)csv=CSV.generate(encoding:'Windows-1251')do|csv|#addheaderscsv:download_report))endindex:downloa